II. AMENDMENTS TO THE CLAIMS 

This listing of claims replaces all prior listings, or versions of claims. 

1 . (Currently Amended) A method of handling a data transfer in a network interface 
controller (NIC), the method comprising the stops of : 

a) receiving the data transfer wherein the data transfer is denoted as one of a first type 
and a second type; 

b) calculating a cyclical redundancy check (CRC) for the data transfer, wherein the CRC 
is one of valid and invalid; and 

c) based on a comparison between a transfer control protocol (TCP) segment length and a 
marker with protocol data unit alignment (MPA) length and validity of a CRC of a direct data 
placement (DDP) segment within the data transfer, conducting one of: 

1) dropping the data transfer and not confirming reception; 

2) placing the data transfer to a reassembly buffer of the NIC; and 

3) placing the data transfer to an internal buffer of the NIC for direct data 
placement to a destination buffer. 

2. (Currently Amended) The method of claim 1 , wherein step c), 2) is conducted in the case 
that the data transfer is of the first type. 

3 . (Currently Amended) The method of claim 1 , further comprising the stop of determining 
whether the data transfer includes a single or multiple direct data placement (DDP) segments. 
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4. (Currently Amended) The method of claim 3, wherein step-c), 3) is conducted in the case 
that the data transfer includes multiple DDP segments and all DDP segments have a valid CRC 
that is fully contained in a TCP segment. 

5. (Currently Amended) The method of claim 3, wherein step c), 1) is conducted in the case 
that the data transfer includes multiple DDP segments, a first DDP segment has an invalid CRC, 
and a DDP header of the first DDP segment is referred by an MPA length associated with a 
previous DDP segment. 

6. (Currently Amended) The method of claim 5, wherein, in the case that the data transfer 
includes multiple DDP segments, a first DDP segment has an invalid CRC, and the DDP header 
of the first DDP segment is not referred by the MPA length associated with the previous DDP 
segment: 

step c), 1) is conducted in the case that the DDP header is referred by an MPA marker; 

and 

step c), 2) is conducted in the case that the DDP header is not referred by the MPA 

marker. 

7. (Currently Amended) The method of claim 3, wherein step c), 1) is conducted in the case 
that the data transfer includes multiple DDP segments and a last DDP segment extends outside of 
the TCP segment boundary; 

and step c), 2) is conducted in the case that the data transfer includes multiple DDP 
segments and a last DDP segment does not extend outside of the TCP segment boundary. 
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8. (Currently Amended) The method of claim 2, wherein step c), 2) is conducted in the case 
that the data transfer includes a single DDP segment and an MPA length associated with the 
single DDP segment is greater than a transmission control protocol (TCP) segment length of the 
data transfer. 

9. (Currently Amended) The method of claim 2, wherein step c), 3) is conducted in the case 
that the data transfer includes a single DDP segment that has: an MPA length associated 
therewith that equals a TCP segment length and a valid CRC. 

10. (Currently Amended) The method of claim 2, wherein step c), 1 ) is conducted in the case 
that the data transfer includes a single DDP segment that has: an MPA length associated 
therewith that equals a TCP segment length, an invalid CRC and a DDP header that is referred 
by an MPA length associated with a previous DDP segment. 

1 1 . (Currently Amended) The method of claim 2, wherein in the case that the data transfer 
includes a single DDP segment that has: an MPA length associated therewith that equals a TCP 
segment length, an invalid CRC and a DDP header that is not referred by an MPA length 
associated with a previous DDP segment: 

step c), 1) is conducted in the case that the DDP header is referred by an MPA marker; 

and 

step c), 2) is conducted in the case that the DDP header is not referred by an MPA 

marker. 
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12. (Currently Amended) The method of claim 1, further comprising the stop of setting the 
data transfer type to the first type when step c), 2) is conducted. 

13. (Currently Amended) The method of claim 1 , wherein in the case that step c), 3) is 
conducted on an out-of-order data transfer, the method further comprises the stops of : 

clearing TCP hole information created by the out-of-order data transfer in a connection 
context; and 

stopping receipt reporting for the out-of-order data transfer. 

14. (Currently Amended) The method of claim 1 , wherein the data transfer includes DDP 
segments, and the calculating step includes calculating a CRC for all DDP segments of the data 
transfer together. 

15. (Original) The method of claim 14, wherein the data transfer does not contain an MPA 
marker. 

16. (Currently Amended) The method of claim 14, further comprising tho stops of : 

storing a number of retransmission attempts for each data transfer including an error; and 
storing a largest sequence number. 



17. (Currently Amended) The method of claim 16, wherein in the case that CRC is invalid 
for the data transfer, which indicates the data transfer is a newly received error-including data 
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transfer: 

step c), 2) is conducted on the newly received error-including data transfer in the case 
that the number of retransmission attempts exceeds a maximum retransmission attempt number 
for that data transfer, and 

step c), 1) is conducted on the newly received error-including data transfer in the case 
that the number of retransmission attempts does not exceed a maximum retransmission attempt 
number for that data transfer; and 

wherein in the case that step c), 1) is conducted, the method further comprises the stops 

ef: 

increasing the number of retransmission attempts for the newly received error- 
including data transfer by one; and 

updating the largest sequence number to carry the largest sequence number 
among at least one previously received error-including data transfer and the newly 
received error-including data transfer. 

18. (Currently Amended) The method of claim 16, wherein in the case that CRC is valid for 
an in-order data transfer: 

a) in the case that a sequence number of the in-order data transfer is greater than the 
stored largest sequence number, the number of retransmission attempts is reset and step c), 3) is 
conducted; and 

b) in the case that the sequence number of the in-order data transfer is not greater than the 
stored largest sequence number, step c), 3) is conducted. 
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19. (Previously Presented) A network interface controller (NIC) for handling a data transfer, 
the NIC comprising: 

first storage means for storing the data transfer for reassembly; 
second storage means for storing the data transfer for direct data placement to a 
destination buffer; 

means for receiving the data transfer wherein the data transfer is denoted as one of a first 
type and a second type; 

means for calculating a cyclical redundancy check (CRC) for the data transfer, wherein 
the CRC is one of valid and invalid; and 

means for, based on a comparison between a transfer control protocol (TCP) segment 
length and a marker with protocol data unit alignment (MPA) length and validity of a CRC of a 
direct data placement (DDP) segment within the data transfer, conducting one of: 

1) dropping the data transfer and not confirming reception; 

2) placing the data transfer to a reassembly buffer of the NIC; and 

3) placing the data transfer to an internal buffer of the NIC for direct data 
placement to a destination buffer. 

20. (Original) The NIC of claim 19, wherein the conducting means conducts c), 2) in the case 
that the data transfer is of the first type. 

21 . (Original) The NIC of claim 19, further comprising means for determining whether the 
data transfer includes a single or multiple direct data placement (DDP) segments. 
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22. (Original) The NIC of claim 21, wherein the conducting means conducts c), 3) in the case 
that the data transfer includes multiple DDP segments and all DDP segments have a valid CRC 
that are fully contained in TCP segment. 

23. (Original) The NIC of claim 21, wherein the conducting means conducts c), 1) in the case 
that the data transfer includes multiple DDP segments, a first DDP segment has an invalid CRC, 
and a DDP header of the first DDP segment is referred by an MPA length associated with a 
previous DDP segment. 

24. (Original) The NIC of claim 2 1 , wherein in the case that the data transfer includes 
multiple DDP segments, a first DDP segment has an invalid CRC, and a DDP header of the first 
DDP segment is not referred by an MPA length associated with a previous DDP segment: 

step c), 1) is conducted in the case that the DDP header is referred by an MPA marker; 

and 

step c), 2) is conducted in the case that the DDP header is not referred by the MPA 

marker. 

25. (Original) The NIC of claim 21, wherein the conducting means conducts c), 1) in the case 
that the data transfer includes multiple DDP segments and a last DDP segment extends outside of 
the TCP segment boundary; 

and conducts c), 2) in the case that the data transfer includes multiple DDP segments and 
a last DDP segment does not extend outside of the TCP segment boundary. 



10/733,734 



Page 8 of 14 



26. (Original) The NIC of claim 21, wherein the conducting means conducts c), 2) in the case 
that the data transfer includes a single DDP segment and an MPA length associated with the 
single DDP segment is greater than a transmission control protocol (TCP) segment length of the 
data transfer. 

27. (Original) The NIC of claim 21, wherein the conducting means conducts c), 3) in the case 
that the data transfer includes a single DDP segment that has: an MPA length associated with the 
single DDP segment that equals a TCP segment length, and a valid CRC. 

28. (Original) The NIC of claim 2 1 , wherein the conducting means conducts c), 1) in the case 
that the data transfer includes a single DDP segment that has: an MPA length associated 
therewith that equals a TCP segment length, an invalid CRC and has a DDP header that is 
referred by an MPA length associated with a previous DDP segment. 

29. (Original) The NIC of claim 28, wherein in the case that the single DDP segment that 
has: an MPA length associated therewith that equals a TCP segment length, an invalid CRC, and 
a DDP header that is not referred by an MPA marker, the conducting means conducts: 

c), 1) in the case that the DDP header is referred by an MPA marker; and 
c), 2) in the case that the DDP header is not referred by an MPA marker. 

30. (Original) The NIC of claim 19, further comprising means for setting the data transfer 
type to the first type when the conducting means conducts c), 2). 
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3 1 . (Original) The NIC of claim 19, further comprising means for clearing TCP hole 
information in a connection context and stopping receipt reporting for an out-of-order data 
transfer upon which the means for conducting conducts c), 3). 

32. (Original) The NIC of claim 19, wherein the data transfer includes DDP segments, and 
the calculating means calculates a CRC for all DDP segments of the data transfer together. 

33. (Original) The NIC of claim 19, wherein the data transfer does not contain an MPA 
marker. 

34. (Original) The NIC of claim 19, further comprising: 

third means for storing a number of retransmission attempts for each data transfer 
including an error; and 

fourth means for storing a largest sequence number. 

35. (Original) The NIC of claim 34, wherein in the case that CRC is invalid for the data 
transfer, which indicates the data transfer is a newly received error-including data transfer: 

the conducting means conducts c), 2) on the newly received error-including data transfer 
in the case that the number of retransmission attempts exceeds a maximum retransmission 
attempt number for that data transfer, and 

the conducting means conducts c), 1) on the newly received error-including data transfer 
in the case that the number of retransmission attempts does not exceed a maximum 
retransmission attempt number for that data transfer; and 
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the NIC further comprising: 

means for increasing the number of retransmission attempts for the newly 
received error-including data transfer by one in the case that the conducting means 
conducts c), 1); and 

means for updating the fourth storing means to carry the largest sequence number 
among at least one previously received error-including data transfer and the newly 
received error-including data transfer in the case that the conducting means conducts c), 
1). 

36. (Original) The NIC of claim 34, further comprising: 

means for resetting the number of retransmission attempts in the case that the CRC is 
valid for an in-order data transfer, and a sequence number of the in-order data transfer is greater 
than the stored largest sequence number; and 

wherein the conducting means conducts c), 3) in the case that: 

a) the CRC is valid for an in-order data transfer and the sequence number of the 
in-order data transfer is not greater than the stored largest sequence number, and 

b) the resetting means resets the number of retransmission attempts. 

37. (Previously Presented) A computer program product comprising a tangible computer 
useable medium having computer readable program code embodied therein, which, when 
executed by a computer infrastructure, enables the computer infrastructure to handle a data 
transfer in a network interface controller (NIC), the program product comprising: 

program code configured to receive the data transfer wherein the data transfer is denoted 
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as one of a first type and a second type; 

program code configured to calculate a cyclical redundancy check (CRC) for the data 
transfer, wherein the CRC is one of valid and invalid; 

program code configured to conduct, based on a comparison between a transfer control 
protocol (TCP) segment length and a marker with protocol data unit alignment (MP A) length and 
validity of a CRC of a direct data placement (DDP) segment within the data transfer, one of: 

1) dropping the data transfer and not confirming reception; 

2) placing the data transfer to a reassembly buffer of the NIC; and 

3) placing the data transfer to an internal buffer of the NIC for direct data 
placement to a destination buffer. 

38. (Original) The program product of claim 37, further comprising program code configured 
to set the data transfer type to the first type when the conducting program code conducts c), 2). 

39. (Original) The program product of claim 37, further comprising program code configured 
to clear TCP hole information in a connection context and stop receipt reporting for an out-of- 
order data transfer upon which the conducting program code conducts c), 3). 

40. (Original) The program product of claim 37, wherein the conducting program code 
conducts c), 2) in the case that the data transfer is of the first type. 
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